<template>
  <div>
    
    <!-- 顶部滑动条区域 -->
    <div id="slider" class="mui-slider">
      <div id="sliderSegmentedControl" class="mui-scroll-wrapper mui-slider-indicator mui-segmented-control mui-segmented-control-inverted">
        <div class="mui-scroll">
          <!--tap事件代替click-->
          <a :class="['mui-control-item',i.id==0?'mui-active':'']" v-for="i in cates" :key="i.id" @tap="getPhotoListByCateId(i.id)">
            {{i.title}}
          </a>

        </div>
      </div>

    </div>

    <!-- 图片列表区域 使用懒加载v-lazy-->
    <ul class="photo-list">
      <!--tag置顶渲染为li标签-->
      <router-link v-for="(item,index) in list" :key="index" to="/home/photoinfo" tag="li" >
        <img v-lazy="item.pic">
        <div class="info">
          <h1 class="info-title">{{ item.title }}</h1>
          <div class="info-body" v-html="item.content"></div>
        </div>
      </router-link>
    </ul>

  </div>
</template>

<script>
// 1. 导入 mui 的js文件
import mui from "../../lib/mui/js/mui.min.js";

export default {
  data() {
    return {
      cates: [], // 所有分类的列表数组
      list: [] // 图片列表的数组
    };
  },
  created() {
    this.getAllCategory();
  //   // 默认进入页面，就主动请求 所有图片列表的数据
    this.getPhotoListByCateId(0);
  },
  mounted() {
    // 组件中的DOM结构被渲染好并放到页面中后，会执行这个 钩子函数
    // 如果要操作元素了，最好在 mounted 里面，因为，这里时候的 DOM 元素 是最新的
    // 初始化滑动控件
      mui("#sliderSegmentedControl").scroll({
          deceleration: 0.0005 //flick 减速系数，系数越大，滚动速度越慢，滚动距离越小，默认值0.0006
      });
  },
  methods: {
    getAllCategory() {
      // 获取所有的图片分类
      this.$http.get("/api/getimgcategory").then(result => {
          if (result.status === 200) {
          // 手动拼接出一个最完整的 分类列表
          result.body.message.unshift({ title: "全部", id: 0 });
          this.cates = result.body.message;
        }
      });
    },
    getPhotoListByCateId(cateId) {
        if(cateId==0){
            this.list=[];
          for(let i=1;i<5;i++){
            this.$http.get("/api/getimages/" + i).then(result => {
                if (result.status === 200) {
                    // result.body.message.forEach(i=>{
                    //     this.list.push(i)
                    // })
                    this.list=this.list.concat(result.body.message);
                }
            });
          }
            this.$http.jsonp('https://api.jisuapi.com/news/get?channel=头条&start=0&num=10&appkey=fae0b7669d8afcbc').then(res=>{
                this.list=this.list.concat(res.body.result.list)
            })

        }
        else if(cateId==5){
            //新闻时事调用新闻API,每次就一百次使用次数
            this.$http.jsonp('https://api.jisuapi.com/news/get?channel=头条&start=0&num=10&appkey=fae0b7669d8afcbc').then(res=>{
                this.list=res.body.result.list
            })
        }
        else{
            // 根据 分类Id，获取图片列表
            this.$http.get("/api/getimages/" + cateId).then(result => {
                if (result.status === 200) {
                    this.list = result.body.message;
                }
            });
        }

    }
  }
};
</script>

<style lang="scss" scoped>
* {
  touch-action: pan-y;
}

.photo-list {
  list-style: none;
  margin: 0;
  padding: 10px;
  padding-bottom: 0;
  li {
    background-color: #ccc;
    text-align: center;
    margin-bottom: 10px;
    box-shadow: 0 0 9px #999;
    position: relative;
    img {
      width: 100%;
      vertical-align: middle;
    }
    img[lazy="loading"] {
      width: 40px;
      height: 300px;
      margin: auto;
    }

    .info {
      color: white;
      text-align: left;
      position: absolute;
      bottom: 0;
      width: 100%;
      /*min-height: 60px;*/
      overflow: hidden;

      background-color: rgba(0, 0, 0, 0.4);
      max-height: 84px;
      .info-title {
        font-size: 14px;
      }
      .info-body {
        font-size: 13px;

      }
    }
  }
}

</style>
